最常用的五类CSS选择器

一些新手朋友对CSS选择器一知半解,不知道在什么情况下运用什么样的CSS选择器,这是一个比较头疼的问题,针对新手朋友,对CSS选择器作一些简单的说明,希望能对大家的学习工作有一定的帮助。 准确而简洁的运用CSS选择器会达到非常好的效果。我们不必通篇给每一个元素定义类(class)或ID,通过合适的组织,可以用最简单的方法实现同样的效果。在实际工作中,最常用的选择器有以下五类:

1. 标签选择器:

顾名思议,标签选择器是直接将HTML标签作为CSS选择器,可以是p、h1、dl、strong等HTML标签。如:

p{
font:12px;
}
em{
color:blue;
}
dl{
float:left;margin-top:10px;
}

2. id选择器:

我们通常给页面元素定义id。例如定义一个层 <div id="menubar"></div> 然后在样式表里这样定义:

#menubar{
margin:0auto;
background:#ccc;
color:#c00;
}

其中”menubar”是你自己定义的id名称。注意在前面加”#”号。 id选择器也同样支持后代选择器,例如:

#menubar p{
text-align:center;line-height:20px;
}

这个方法主要用来定义层和那些比较复杂,有多个唯一后代的元素。

3. 类(class)选择器:

在CSS里用一个点开头表示类别选择器定义,例如:

.da1{
color:#f60;
font-size:14px;
}

在页面中,用 class="类别名" 的方法调用: <span class="da1">14px大小的字体</span> 这个方法比较简单灵活,可以随时根据页面需要新建和删除。但需要避免多class综合症。

4. 群组选择器:

当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,这就是CSS选择器中的群组选择器。如:

p, td, li{
line-height:20px;
color:#c00;
}
#main p, #sider span{
color:#000;
line-height:26px;
}
.com, #main p span{
color:#f60;
}
.text1 h1, #sider h3, .art_title h2{
font-weight:100;
}

使用组群选择器,将会大大的减化CSS代码,将具有多个相同属性的元素,合并群组进行选择,定义同样的CSS属性,这大大的提高了编码效率与CSS文件体积。

5. 后代选择器:

CSS选择器中的后代选择器也叫派生选择器。可以使用后代选择器给一个元素里的子元素定义样式,例如这样:

li strong{
font-style:italic;
font-weight:800;
color:#f00;
}
#main p{
color:#000;
line-height:26px;
}
#sider .con span{
color:#000;
line-height:26px;
}
.comp span{
color:#f60;
}
#sider ul li.subnav1{
margin-top:5px;
}

第一段,就是给li下面的子元素strong定义一个斜体加粗而且套红的样式。其他以此类推。 后代选择器的使用是非常有益的,如果父元素内包括的HTML元素具有唯一性,则不必给内部元素再指定class或id,直接应用此选择器即可。

结合使用上面的四种CSS选择器,基本满足了CSS布局的需要,主要在于灵活的使用,特别是后代选择器的使用能大大的简化HTML文档,使HTML做到结构化明确,最小的代码实现同样的效果。